package com.huike.web.controller.review;

import com.huike.common.core.controller.BaseController;
import com.huike.common.core.domain.AjaxResult;
import com.huike.common.core.page.TableDataInfo;
import com.huike.review.pojo.Review;
import com.huike.review.service.ReviewService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.*;

import java.util.List;

/**
 * 该Controller主要是为了复习三层架构以及Mybatis使用的，该部分接口已经放开权限，可以直接访问
 * 同学们在此处编写接口通过浏览器访问看是否能完成最简单的增删改查
 */
@RestController
@RequestMapping("/review")
public class MybatisReviewController extends BaseController {

    @Autowired
    private ReviewService reviewService;

    //=========================================================新增数据============================================
    @GetMapping("/saveData/{name}/{age}/{sex}")
    public AjaxResult saveData1(@PathVariable String name, @PathVariable String age, @PathVariable String sex) {
        int i = reviewService.saveData1(name, age, sex);
        return i > 0 ? AjaxResult.success("成功插入:" + i + "条数据") : AjaxResult.error("插入失败");
    }

    @PostMapping("/saveData")
    public AjaxResult saveData2(@RequestBody Review review) {
        int i = reviewService.saveData2(review);
        return i > 0 ? AjaxResult.success("成功插入:" + i + "条数据") : AjaxResult.error("插入失败");
    }

    //=========================================================删除数据============================================

    @DeleteMapping("/remove/{id}")
    public AjaxResult deleteById(@PathVariable Long id) {
        int i = reviewService.deleteById(id);
        return i > 0 ? AjaxResult.success("成功删除:" + i + "条数据") : AjaxResult.error("删除失败");
    }
    //=========================================================修改数据=============================================

    @PostMapping("update")
    public AjaxResult updateReview(@RequestBody Review review) {
        boolean flag = reviewService.update(review);
        return flag ? AjaxResult.success("修改成功") : AjaxResult.error("修改失败");
    }

    //=========================================================查询数据=============================================
    @GetMapping("getById")
    public AjaxResult selectById(@RequestParam Long id) {
        Review review = reviewService.selectById(id);
        return review != null ? AjaxResult.success("操作成功", review) : AjaxResult.error("查询失败");
    }

    @GetMapping("getDataByPage")
    public TableDataInfo selectByPage(@RequestParam int pageNum, @RequestParam int pageSize) {
        startPage();
        List<Review> list = reviewService.selectByPage();
        return getDataTable(list);
    }
}